博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
发布功能完成
阅读量:4982 次
发布时间:2019-06-12

本文共 4035 字,大约阅读时间需要 13 分钟。

  • 编写要求登录的装饰器

from functools import wraps

def loginFirst(func): #参数是函数

@wraps(func)

      def wrapper(*args, ** kwargs): #定义个函数将其返回

          #要求登录

          return func(*args, ** kwargs)

      return wrapper #返回一个函数

  • 应用装饰器,要求在发布前进行登录,登录后可发布。
@app.route('/question/',methods=['GET','POST']) @loginFirst def question():

 

  • 建立发布内容的对象关系映射。
class Question(db.Model):
  • 完成发布函数。

保存到数据库。

重定向到首页。

{% extends 'basic.html' %}{% block title %}登录{% endblock %}{% block head %}    
{% endblock %}{% block question %}

发布问答

{% endblock %}
from flask_sqlalchemy import SQLAlchemyimport configfrom flask import Flask,render_template,request,redirect, url_for,sessionfrom functools import wrapsfrom datetime import datetimeapp = Flask(__name__)app.config.from_object(config)db=SQLAlchemy(app)class User(db.Model):    __tablename__ = 'User'    id = db.Column(db.Integer,primary_key=True,autoincrement=True)    username = db.Column(db.String(20),nullable=False)    password = db.Column(db.String(20),nullable=False)    nickname = db.Column(db.String(20))class Question(db.Model):     __tablename__ = 'question'     id = db.Column(db.Integer,primary_key=True,autoincrement=True)     title = db.Column(db.String(100),nullable=False)     detail = db.Column(db.Text,nullable=False)     creat_time=db.Column(db.DateTime,default=datetime.now)     author_id=db.Column(db.Integer,db.ForeignKey('User.id'))     author= db.relationship('User',backref=db.backref('question'))#db.create_all()@app.route('/')def index():    return render_template('index.html')@app.route('/login/',methods=['GET','POST'])def login():    if request.method == 'GET':        return render_template('login.html')    else:        usern = request.form.get('username')        passw = request.form.get('password')        user = User.query.filter(User.username == usern).first()        if user:            if user.password==passw:                session['user'] = usern                session.permanent = True                return redirect(url_for('index'))            else:                return u'password error'        else:            return u'password is not existed'@app.route('/rege/',methods=['GET','POST'])def rege():    if request.method =='GET':        return render_template('rege.html')    else:        usern = request.form.get('username')        passw = request.form.get('password')        nickn = request.form.get('nickname')        user = User.query.filter(User.username ==usern).first()        if user:            return 'username.existed.'        else:            user1 = User(username=usern,password=passw,nickname = nickn)            db.session.add(user1)            db.session.commit()            return redirect(url_for('login'))def loginFrist(func):    @wraps(func)    def wrapper(*args, **kwargs):        if session.get('user'):            return func(*args, **kwargs)        else:            return redirect(url_for('login'))    return wrapper@app.route('/question/', methods=['GET', 'POST'])@loginFristdef question():    if request.method == 'GET':        return render_template('question.html')    else:        title = request.form.get('title')        detail = request.form.get('detail')        author_id = User.query.filter(User.username == session.get('user')).first().id        question = Question(title=title, detail=detail, author_id=author_id)        db.session.add(question)        db.session.commit()        return redirect(url_for('index'))@app.context_processordef mycontext():    usern=session.get('user')    if usern:        return{
'username':usern} else: return{}@app.route('/logout/')def logout(): session.clear() return redirect(url_for('index'))if __name__=="__main__": app.run(debug=True)

 

转载于:https://www.cnblogs.com/dujiacheng789/p/7922485.html

你可能感兴趣的文章
华为双系统手机可以刷成单系统_华为手机双系统,1部手机能当2部用,打开3秒就能切换,真厉害...
查看>>
adb查看topactivity_使用adb shell dumpsys检测Android的Activity任务栈
查看>>
ext grid新增时默认值_HTMLCSS学习笔记(二十三)-- GRID布局
查看>>
重置mysql数据库_如何重置mysql数据库
查看>>
mysql安装目录utf8_彻底解决MySql在UTF8字符集下乱码问题
查看>>
mysql缺失关键字_ORA-00928: 缺失 SELECT 关键字
查看>>
mysql sp cursoropen_三个重要的游标sp_cursoropen
查看>>
mysql javadbaccess_【转】Java连接Mysql,SQL Server, Access,Oracle
查看>>
mysql项目案例电影_mysql数据库实战之优酷项目
查看>>
python excel数据框_python-将excel中的某些列读取到数据框
查看>>
linux page结构定义,page结构体,何处安放你的灵魂?
查看>>
c语言tempfile错误,C语言文件问题
查看>>
c语言打印格式大全,C语言printf()输出格式大全
查看>>
c语言删增,C语言中初始、增加和删除进程信号的操作方法简介
查看>>
c语言中sam的用法,C-SAM基本操作手册及了解.pdf
查看>>
android城市二级选择器,Android城市选择器源码实现
查看>>
android监听wifi状态广播,android广播监控wifi连接状态
查看>>
华为承认没有鸿蒙,不超过300年!任正非公开承认:华为鸿蒙短期无法超越安卓苹果...
查看>>
鸿蒙狙击谷歌,谷歌开放新操作系统Fuchsia,网友:这是要狙击华为鸿蒙系统呀...
查看>>
android手机登录界面代码,Android登录界面的实现代码分享
查看>>